草庐IT

python - SSIS 执行流程任务 Python 脚本

全部标签

ruby-on-rails - 我如何在 rake 任务中强制使用 RAILS_ENV?

我有这个小佣金任务:namespace:dbdonamespace:testdotask:resetdoENV['RAILS_ENV']="test"Rake::Task['db:drop'].invokeRake::Task['db:create'].invokeRake::Task['db:migrate'].invokeendendend现在,当我执行时,它将忽略我尝试硬编码的RAILS_ENV。我如何使这个任务按预期工作 最佳答案 对于这个特定的任务,您只需要更改数据库连接,正如Adam指出的那样,您可以这样做:namesp

ruby - Rake vs. Thor 的自动化脚本?

我想自动执行以下操作:使用预先选择的数据库创建一个新的RubyonRails应用程序,Git初始化它,创建一个Heroku项目,提交所有文件等。通过SSH将文件夹中的所有文件上传到另一台计算机,但不要覆盖文件。升级Ubuntu,通过apt-get安装所有基础包。据我所知,这方面的工具是Rake和Thor,但是,我应该使用哪一个?在我看来,Rake实际上更受欢迎。我听说有人推荐托尔。这些在概要中如何相互对应? 最佳答案 Rake和Thor有不同的用途。Rake是一个针对特定项目的通用构建脚本工具。换句话说,您将rakefile放入您的

ruby - 解析 Ruby 脚本中的命令行参数

我想从命令行调用Ruby脚本,并传入键/值对参数。命令行调用:$rubymy_script.rb--first_name=donald--last_name=knuth我的脚本.rb:putsargs.first_name+args.last_name执行此操作的标准Ruby方法是什么?在其他语言中,我通常必须使用选项解析器。在Ruby中,我看到我们有ARGF.read,但这似乎无法像本例中的键/值对那样工作。OptionParser看起来很有希望,但我不知道它是否真的支持这种情况。 最佳答案 Ruby的内置OptionParser

ruby - 如何明确地使 ruby​​ rake 中的任务失败?

假设我有一个这样的rakefile:file'file1'=>some_dependenciesdosh'externaltoolIdonothavecontrolover,whichsometimesfailtocreatethefile'???endtask:default=>'file1'doputs"everything'sOK"end现在,如果我不放置任何内容来代替???,即使外部工具无法生成文件,我也会收到OK消息。什么是通知rake的正确方法,'file1'任务失败了,它应该中止(希望呈现一个有意义的消息——比如哪个任务失败了)——我现在唯一能想到的就是在那里引发异常,但

ruby - 让 sidekiq 立即执行作业

目前,我有一个像这样的sidekiq工作:classSyncUserincludeSidekiq::Workerdefperform(user_id)#dostuffendend我正在像这样在队列中放置一个作业:SyncUser.perform_asyncuser.id当然这一切都有效,但在调用perform_async和作业实际执行之间有一点延迟。我还能做些什么来告诉sidekiq立即执行作业吗? 最佳答案 这里有两个问题。如果你想立即执行一个作业,在当前上下文中你可以使用:SyncUser.new.perform(user.id

ruby - 如何获取当前rake任务的PID?

我将收割机线放入rake任务中,以杀死一些额外生成的ruby​​任务,因为它们有时会不知何故爬上来。system"psaux|grep'namespace:taskname'|grepruby|grep-vgrep|awk'{print$2}'|xargskill-9;echo'Reapedoldnamespace:tasknameprocesses.'"我想在其中添加grep-v$PID_OF_CURRENT_TASK以确保我不会终止当前正在运行的任务。我如何获得该PID? 最佳答案 您可以使用Process.pid在Ruby中获

ruby - 我应该在我的 ruby​​ 脚本中定义一个 main 方法吗?

在python中,模块没有有一个main函数,但通常的做法是使用以下习惯用法:defmy_main_function():...#somecodeif__name__=="__main__":#program'sentrypointmy_main_function()我知道Ruby也没有main方法,但是有什么我应该遵循的最佳实践吗?我应该将我的方法命名为main还是什么?Wikipediapageaboutmainmethods对我没有真正的帮助。作为旁注,我还在python中看到了以下习语:defmy_main_function(args=[]):...#somecodeif__n

ruby-on-rails - 从迁移中执行 Rake 任务?

我有一个Rake任务将配置数据从文件加载到数据库中,是否有正确的ruby​​/rails方法在迁移时调用它?我的目标是同步我的团队数据库配置,无需广播然后运行任务lalaladefself.upchange_table:fis_situacao_fiscaldo|t|t.remove:mostrar_enderecot.rename:serie,:modeloendFaturamento::Cfop.destroy_all()#performrakehere!end更新我现在的工作方式和工作方式:system('rakesistema:load_datafile=faturamento

ruby-on-rails - Ruby/Rails 有没有办法执行字符串中的代码?

所以我有一个包含不同代码示例(阅读片段)的数据库。代码示例由用户创建。在Rails中有没有办法执行它?例如,我的数据库中有以下代码(id=123):return@var.reverse有没有办法让我执行它?像这样的东西:@var='Hello'@result=exec(CodeSample.find(123))所以结果会是'olleH' 最佳答案 您可以使用eval:code='@var.reverse'@var='Hello'@result=eval(code)#=>"olleH"但是这样做要非常小心;您授予该代码对您系统的完全访

ruby - 在 Rspec 测试中运行 Rake 任务

我正在构建一个集成测试套件,我需要一个干净的数据库来处理一些逻辑。如何在我的一个测试中运行db:test:purge任务?我正在使用:ruby1.9.2、rails3.0.9、rspec2.6 最佳答案 您可以按如下方式调用Rake任务:require'rake'Rake::Task[name].invoke在这种情况下,这将导致以下代码:require'rake'Rake::Task['db:test:purge'].invoke 关于ruby-在Rspec测试中运行Rake任务,我们